<?php
/**
 *  User：LRZ
 *  Date：2020/2/11
 *  Time：14:56
 */

/**
 *  171.Excel表列序号
 *
 *  标签：数学
 *
 *  给定一个Excel表格中的列名称，返回其相应的列序号。
 *  例如：
 *      A -> 1
 *      B -> 2
 *      C -> 3
 *      ...
 *      Z -> 26
 *      AA -> 27
 *      AB -> 28
 *      ...
 *
 *  示例 1:
 *      输入: "A"
 *      输出: 1
 *
 *  示例 2:
 *      输入: "AB"
 *      输出: 28
 *
 *  示例 3:
 *      输入: "ZY"
 *      输出: 701
 *
 *  来源：力扣（LeetCode）
 *  链接：https://leetcode-cn.com/problems/excel-sheet-column-number
 *  著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */

$start = microtime(true);

$s   = 'Z';
$res = titleToNumber($s);

$end = microtime(true);
print_r($res);
printf(' total run: %.2f s<br>' . 'memory usage: %.2f M<br> ', $end - $start, memory_get_usage() / 1024 / 1024);

function titleToNumber($s)
{
    $size = strlen($s);
    $res  = 0;
    for ($i = 0; $i < $size; $i++) {
        $num = ord($s[$i]) - 65 + 1;
        $res = $res * 26 + $num;
    }
    return $res;
}